home *** CD-ROM | disk | FTP | other *** search
/ PC-Blue - MS DOS Public Domain Library / PC-Blue MS-DOS Public Domain Library - NYACC.iso / vol117 / listper.bas (.txt) < prev    next >
Encoding:
GW-BASIC  |  1986-12-15  |  3.9 KB  |  137 lines

  1. 90  WIDTH "scrn:", 80
  2. 95  SCREEN 0,1,0,0
  3. 100  TITLE$ = "List the Persons File Program"
  4. 105  TITLE$ = TITLE$ + " ON DISPLAY"
  5. 110  VERSION$ = "Version 3.0"
  6. 115  COPY1$ = "Copyright (c) 1983, 1984, 1985, by:"
  7. 120  COPY2$ = "Melvin O. Duke"
  8. 125  PRICE$ = "$35"
  9. 130  ADDR1$ = "Melvin O. Duke"
  10. 135  ADDR2$ = "P. O. Box 20836"
  11. 140  ADDR3$ = "San Jose, CA  95160"
  12. 145  REM Dimension Statements go here
  13. 170  REM Produce the first screen
  14. 175  KEY OFF : CLS
  15. 180  REM Draw the outer double box
  16. 185  R1 = 1 : C1 = 1 : R2 = 24 : C2 = 79 : GOSUB 400
  17. 190  REM Find the title location
  18. 195  TITLE.POS = 40 - INT(LEN(TITLE$)/2)
  19. 200  REM Draw the title box
  20. 205  R1=3:C1=TITLE.POS-2:R2=6:C2=TITLE.POS+LEN(TITLE$)+1:GOSUB 600
  21. 210  REM Print the title
  22. 215  LOCATE 4,TITLE.POS : PRINT TITLE$
  23. 220  LOCATE 5,40-INT(LEN(VERSION$)/2) :  PRINT VERSION$;
  24. 225  REM Draw the Contribution box
  25. 230  R1 = 8 : C1 = 19 : R2 = 17 : C2 = 62 : GOSUB 400
  26. 235  REM Request the Contribution
  27. 240  LOCATE 9,23 : PRINT "If you are using these programs, and"
  28. 245  LOCATE 10,21 : PRINT "finding them of value, your contribution"
  29. 250  LOCATE 11,23 : PRINT "("+PRICE$+" suggested) will be anticipated."
  30. 255  REM Draw the Mailing Label
  31. 260  R1 = 12 : C1 = 28 : R2 = 16 : C2 = 52 : GOSUB 600
  32. 265  REM Print the Name and Address
  33. 270  LOCATE 13,40-INT(LEN(ADDR1$)/2) :  PRINT ADDR1$;
  34. 275  LOCATE 14,40-INT(LEN(ADDR2$)/2) :  PRINT ADDR2$;
  35. 280  LOCATE 15,40-INT(LEN(ADDR3$)/2) :  PRINT ADDR3$;
  36. 285  REM Draw the Copyright box
  37. 290  R1 = 19 : C1 = 21 : R2 = 22 : C2 = 59 : GOSUB 400
  38. 295  REM Print the Copyright
  39. 300  LOCATE 20,40-INT(LEN(COPY1$)/2) :  PRINT COPY1$;
  40. 305  LOCATE 21,40-INT(LEN(COPY2$)/2) :  PRINT COPY2$;
  41. 310  GOTO 740
  42. 400  REM subroutine to print a double box
  43. 405  COLOR 5
  44. 410  FOR I = R1 + 1 TO R2 - 1
  45. 420   LOCATE I, C1 : PRINT CHR$(186);
  46. 430   LOCATE I, C2 : PRINT CHR$(186);
  47. 440  NEXT I
  48. 450  FOR J = C1 + 1 TO C2 - 1
  49. 460   LOCATE R1, J : PRINT CHR$(205);
  50. 470   LOCATE R2, J : PRINT CHR$(205);
  51. 480  NEXT J
  52. 490   LOCATE R1, C1 : PRINT CHR$(201);
  53. 500   LOCATE R1, C2 : PRINT CHR$(187);
  54. 510   LOCATE R2, C1 : PRINT CHR$(200);
  55. 520   LOCATE R2, C2 : PRINT CHR$(188);
  56. 525  COLOR 7
  57. 530  RETURN
  58. 600  REM subroutine to print a single box
  59. 605  COLOR 3
  60. 610  FOR I = R1 + 1 TO R2 - 1
  61. 620   LOCATE I, C1 : PRINT CHR$(179);
  62. 630   LOCATE I, C2 : PRINT CHR$(179);
  63. 640  NEXT I
  64. 650  FOR J = C1 + 1 TO C2 - 1
  65. 660   LOCATE R1, J : PRINT CHR$(196);
  66. 670   LOCATE R2, J : PRINT CHR$(196);
  67. 680  NEXT J
  68. 690   LOCATE R1, C1 : PRINT CHR$(218);
  69. 700   LOCATE R1, C2 : PRINT CHR$(191);
  70. 710   LOCATE R2, C1 : PRINT CHR$(192);
  71. 720   LOCATE R2, C2 : PRINT CHR$(217);
  72. 725  COLOR 7
  73. 730  RETURN
  74. 740  REM ask user to press a key to continue
  75. 750  LOCATE 25,1
  76. 760  PRINT "Have Data Diskette(s) in Place, then Press any key to continue.";
  77. 770  K$ = INKEY$ : IF K$ = "" THEN 770
  78. 780  CLS
  79. 1000  REM List the Persons File.
  80. 1010  REM By:  Melvin O. Duke.  Last Updated:  24 December 1984.
  81. 1020  OPEN "a:persfile" AS #1 LEN = 256
  82. 1030  FIELD 1, 5 AS F1$, 20 AS F2$, 30 AS F3$, 2 AS F4$, 5 AS F5$, 5 AS F6$, 5 AS F7$, 11 AS F8$, 18 AS F9$, 16 AS F10$, 16 AS F11$, 11 AS F12$, 18 AS F13$, 16 AS F14$, 16 AS F15$, 11 AS F16$, 18 AS F17$, 16 AS F18$, 16 AS F19$
  83. 1040  REM Read all records, and print the actual ones
  84. 1050  K = 0
  85. 1060  CLS : LOCATE 21,1
  86. 1070  PRINT "Printing a List of Records in the Persons File"
  87. 1080  GOSUB 1100
  88. 1090  GOTO 1150
  89. 1100  LPRINT "       List of the Records in the Persons File  ";DATE$;"  ";TIME$
  90. 1110  LPRINT
  91. 1120  LPRINT "     REC GIVEN NAMES-SURNAME";TAB(50);"BIRTHDATE    FATHER  MOTHER
  92. 1130  LPRINT "     --- -------------------";TAB(50);"-----------  ------  ------
  93. 1140  RETURN
  94. 1150  FOR I = 1 TO 500
  95. 1160  GET #1, I
  96. 1170  LOCATE 23,1 : PRINT "Printing Record:";I
  97. 1180  REM Extract information from the file for use
  98. 1190  T1 = CVS(F1$)
  99. 1200  IF T1 < 1 THEN 1520
  100. 1210  K = K + 1
  101. 1220  T2$ = F2$
  102. 1230  FOR J = 1 TO LEN(F2$)-1
  103. 1240   IF RIGHT$(T2$,1)=" "THEN T2$ = LEFT$(T2$,LEN(T2$)-1) ELSE J = LEN(F2$)-1
  104. 1250  NEXT J
  105. 1260  T3$ = F3$
  106. 1270  FOR J = 1 TO LEN(F3$)-1
  107. 1280   IF RIGHT$(T3$,1)=" "THEN T3$ = LEFT$(T3$,LEN(T3$)-1) ELSE J = LEN(F3$)-1
  108. 1290  NEXT J
  109. 1300  T4$ = F4$
  110. 1310  IF LEFT$(T4$,1) = "M" THEN T4$ = "Male"
  111. 1320  IF LEFT$(T4$,1) = "F" THEN T4$ = "Female"
  112. 1330  T5 = CVS(F5$)
  113. 1340  T6 = CVS(F6$)
  114. 1350  T7 = CVS(F7$)
  115. 1360  T8$ = F8$
  116. 1370  T9$ = F9$
  117. 1380  T10$ = F10$
  118. 1390  T11$ = F11$
  119. 1400  T12$ = F12$
  120. 1410  T13$ = F13$
  121. 1420  T14$ = F14$
  122. 1430  T15$ = F15$
  123. 1440  T16$ = F16$
  124. 1450  T17$ = F17$
  125. 1460  T18$ = F18$
  126. 1470  T19$ = F19$
  127. 1480  LPRINT USING "########";T1;
  128. 1490  LPRINT " "; T3$; " "; T2$, TAB(50); T8$;
  129. 1500  LPRINT USING "######  ######";T6, T7
  130. 1510  IF K MOD 55 = 0 THEN LPRINT CHR$(12);: GOSUB 1100
  131. 1520  NEXT I
  132. 1530  CLOSE #1
  133. 1540  LPRINT CHR$(12);
  134. 1550  CLS : LOCATE 21,1
  135. 1560  PRINT "End of Program"
  136. 1570  RUN "a:menu"
  137.